@@ -0,0 +1,3 @@ |
||
| 1 |
+{
|
|
| 2 |
+ "directory": "bower_components" |
|
| 3 |
+} |
@@ -0,0 +1,21 @@ |
||
| 1 |
+# EditorConfig helps developers define and maintain consistent |
|
| 2 |
+# coding styles between different editors and IDEs |
|
| 3 |
+# editorconfig.org |
|
| 4 |
+ |
|
| 5 |
+root = true |
|
| 6 |
+ |
|
| 7 |
+ |
|
| 8 |
+[*] |
|
| 9 |
+ |
|
| 10 |
+# Change these settings to your own preference |
|
| 11 |
+indent_style = space |
|
| 12 |
+indent_size = 2 |
|
| 13 |
+ |
|
| 14 |
+# We recommend you to keep these unchanged |
|
| 15 |
+end_of_line = lf |
|
| 16 |
+charset = utf-8 |
|
| 17 |
+trim_trailing_whitespace = true |
|
| 18 |
+insert_final_newline = true |
|
| 19 |
+ |
|
| 20 |
+[*.md] |
|
| 21 |
+trim_trailing_whitespace = false |
@@ -0,0 +1 @@ |
||
| 1 |
+* text=auto |
@@ -0,0 +1,5 @@ |
||
| 1 |
+node_modules |
|
| 2 |
+dist |
|
| 3 |
+.tmp |
|
| 4 |
+.sass-cache |
|
| 5 |
+bower_components |
@@ -0,0 +1,23 @@ |
||
| 1 |
+{
|
|
| 2 |
+ "node": true, |
|
| 3 |
+ "browser": true, |
|
| 4 |
+ "esnext": true, |
|
| 5 |
+ "bitwise": true, |
|
| 6 |
+ "camelcase": true, |
|
| 7 |
+ "curly": true, |
|
| 8 |
+ "eqeqeq": true, |
|
| 9 |
+ "immed": true, |
|
| 10 |
+ "indent": 2, |
|
| 11 |
+ "latedef": true, |
|
| 12 |
+ "newcap": true, |
|
| 13 |
+ "noarg": true, |
|
| 14 |
+ "quotmark": "single", |
|
| 15 |
+ "undef": true, |
|
| 16 |
+ "unused": true, |
|
| 17 |
+ "strict": true, |
|
| 18 |
+ "trailing": true, |
|
| 19 |
+ "smarttabs": true, |
|
| 20 |
+ "globals": {
|
|
| 21 |
+ "angular": false |
|
| 22 |
+ } |
|
| 23 |
+} |
@@ -0,0 +1,9 @@ |
||
| 1 |
+sudo: false |
|
| 2 |
+language: node_js |
|
| 3 |
+node_js: |
|
| 4 |
+ - 'iojs' |
|
| 5 |
+ - '0.12' |
|
| 6 |
+ - '0.10' |
|
| 7 |
+before_script: |
|
| 8 |
+ - 'npm install -g bower grunt-cli' |
|
| 9 |
+ - 'bower install' |
@@ -0,0 +1 @@ |
||
| 1 |
+{}
|
@@ -0,0 +1,444 @@ |
||
| 1 |
+// Generated on 2015-05-16 using generator-angular 0.11.1 |
|
| 2 |
+'use strict'; |
|
| 3 |
+ |
|
| 4 |
+// # Globbing |
|
| 5 |
+// for performance reasons we're only matching one level down: |
|
| 6 |
+// 'test/spec/{,*/}*.js'
|
|
| 7 |
+// use this if you want to recursively match all subfolders: |
|
| 8 |
+// 'test/spec/**/*.js' |
|
| 9 |
+ |
|
| 10 |
+module.exports = function (grunt) {
|
|
| 11 |
+ |
|
| 12 |
+ // Load grunt tasks automatically |
|
| 13 |
+ require('load-grunt-tasks')(grunt);
|
|
| 14 |
+ |
|
| 15 |
+ // Time how long tasks take. Can help when optimizing build times |
|
| 16 |
+ require('time-grunt')(grunt);
|
|
| 17 |
+ |
|
| 18 |
+ // Configurable paths for the application |
|
| 19 |
+ var appConfig = {
|
|
| 20 |
+ app: require('./bower.json').appPath || 'app',
|
|
| 21 |
+ dist: 'dist' |
|
| 22 |
+ }; |
|
| 23 |
+ |
|
| 24 |
+ // Define the configuration for all the tasks |
|
| 25 |
+ grunt.initConfig({
|
|
| 26 |
+ |
|
| 27 |
+ // Project settings |
|
| 28 |
+ yeoman: appConfig, |
|
| 29 |
+ |
|
| 30 |
+ // Watches files for changes and runs tasks based on the changed files |
|
| 31 |
+ watch: {
|
|
| 32 |
+ bower: {
|
|
| 33 |
+ files: ['bower.json'], |
|
| 34 |
+ tasks: ['wiredep'] |
|
| 35 |
+ }, |
|
| 36 |
+ js: {
|
|
| 37 |
+ files: ['<%= yeoman.app %>/scripts/{,*/}*.js'],
|
|
| 38 |
+ tasks: ['newer:jshint:all'], |
|
| 39 |
+ options: {
|
|
| 40 |
+ livereload: '<%= connect.options.livereload %>' |
|
| 41 |
+ } |
|
| 42 |
+ }, |
|
| 43 |
+ jsTest: {
|
|
| 44 |
+ files: ['test/spec/{,*/}*.js'],
|
|
| 45 |
+ tasks: ['newer:jshint:test', 'karma'] |
|
| 46 |
+ }, |
|
| 47 |
+ styles: {
|
|
| 48 |
+ files: ['<%= yeoman.app %>/styles/{,*/}*.css'],
|
|
| 49 |
+ tasks: ['newer:copy:styles', 'autoprefixer'] |
|
| 50 |
+ }, |
|
| 51 |
+ gruntfile: {
|
|
| 52 |
+ files: ['Gruntfile.js'] |
|
| 53 |
+ }, |
|
| 54 |
+ livereload: {
|
|
| 55 |
+ options: {
|
|
| 56 |
+ livereload: '<%= connect.options.livereload %>' |
|
| 57 |
+ }, |
|
| 58 |
+ files: [ |
|
| 59 |
+ '<%= yeoman.app %>/{,*/}*.html',
|
|
| 60 |
+ '.tmp/styles/{,*/}*.css',
|
|
| 61 |
+ '<%= yeoman.app %>/images/{,*/}*.{png,jpg,jpeg,gif,webp,svg}'
|
|
| 62 |
+ ] |
|
| 63 |
+ } |
|
| 64 |
+ }, |
|
| 65 |
+ |
|
| 66 |
+ // The actual grunt server settings |
|
| 67 |
+ connect: {
|
|
| 68 |
+ options: {
|
|
| 69 |
+ port: 9000, |
|
| 70 |
+ // Change this to '0.0.0.0' to access the server from outside. |
|
| 71 |
+ hostname: 'localhost', |
|
| 72 |
+ livereload: 35729 |
|
| 73 |
+ }, |
|
| 74 |
+ livereload: {
|
|
| 75 |
+ options: {
|
|
| 76 |
+ open: true, |
|
| 77 |
+ middleware: function (connect) {
|
|
| 78 |
+ return [ |
|
| 79 |
+ connect.static('.tmp'),
|
|
| 80 |
+ connect().use( |
|
| 81 |
+ '/bower_components', |
|
| 82 |
+ connect.static('./bower_components')
|
|
| 83 |
+ ), |
|
| 84 |
+ connect().use( |
|
| 85 |
+ '/app/styles', |
|
| 86 |
+ connect.static('./app/styles')
|
|
| 87 |
+ ), |
|
| 88 |
+ connect.static(appConfig.app) |
|
| 89 |
+ ]; |
|
| 90 |
+ } |
|
| 91 |
+ } |
|
| 92 |
+ }, |
|
| 93 |
+ test: {
|
|
| 94 |
+ options: {
|
|
| 95 |
+ port: 9001, |
|
| 96 |
+ middleware: function (connect) {
|
|
| 97 |
+ return [ |
|
| 98 |
+ connect.static('.tmp'),
|
|
| 99 |
+ connect.static('test'),
|
|
| 100 |
+ connect().use( |
|
| 101 |
+ '/bower_components', |
|
| 102 |
+ connect.static('./bower_components')
|
|
| 103 |
+ ), |
|
| 104 |
+ connect.static(appConfig.app) |
|
| 105 |
+ ]; |
|
| 106 |
+ } |
|
| 107 |
+ } |
|
| 108 |
+ }, |
|
| 109 |
+ dist: {
|
|
| 110 |
+ options: {
|
|
| 111 |
+ open: true, |
|
| 112 |
+ base: '<%= yeoman.dist %>' |
|
| 113 |
+ } |
|
| 114 |
+ } |
|
| 115 |
+ }, |
|
| 116 |
+ |
|
| 117 |
+ // Make sure code styles are up to par and there are no obvious mistakes |
|
| 118 |
+ jshint: {
|
|
| 119 |
+ options: {
|
|
| 120 |
+ jshintrc: '.jshintrc', |
|
| 121 |
+ reporter: require('jshint-stylish')
|
|
| 122 |
+ }, |
|
| 123 |
+ all: {
|
|
| 124 |
+ src: [ |
|
| 125 |
+ 'Gruntfile.js', |
|
| 126 |
+ '<%= yeoman.app %>/scripts/{,*/}*.js'
|
|
| 127 |
+ ] |
|
| 128 |
+ }, |
|
| 129 |
+ test: {
|
|
| 130 |
+ options: {
|
|
| 131 |
+ jshintrc: 'test/.jshintrc' |
|
| 132 |
+ }, |
|
| 133 |
+ src: ['test/spec/{,*/}*.js']
|
|
| 134 |
+ } |
|
| 135 |
+ }, |
|
| 136 |
+ |
|
| 137 |
+ // Empties folders to start fresh |
|
| 138 |
+ clean: {
|
|
| 139 |
+ dist: {
|
|
| 140 |
+ files: [{
|
|
| 141 |
+ dot: true, |
|
| 142 |
+ src: [ |
|
| 143 |
+ '.tmp', |
|
| 144 |
+ '<%= yeoman.dist %>/{,*/}*',
|
|
| 145 |
+ '!<%= yeoman.dist %>/.git{,*/}*'
|
|
| 146 |
+ ] |
|
| 147 |
+ }] |
|
| 148 |
+ }, |
|
| 149 |
+ server: '.tmp' |
|
| 150 |
+ }, |
|
| 151 |
+ |
|
| 152 |
+ // Add vendor prefixed styles |
|
| 153 |
+ autoprefixer: {
|
|
| 154 |
+ options: {
|
|
| 155 |
+ browsers: ['last 1 version'] |
|
| 156 |
+ }, |
|
| 157 |
+ server: {
|
|
| 158 |
+ options: {
|
|
| 159 |
+ map: true, |
|
| 160 |
+ }, |
|
| 161 |
+ files: [{
|
|
| 162 |
+ expand: true, |
|
| 163 |
+ cwd: '.tmp/styles/', |
|
| 164 |
+ src: '{,*/}*.css',
|
|
| 165 |
+ dest: '.tmp/styles/' |
|
| 166 |
+ }] |
|
| 167 |
+ }, |
|
| 168 |
+ dist: {
|
|
| 169 |
+ files: [{
|
|
| 170 |
+ expand: true, |
|
| 171 |
+ cwd: '.tmp/styles/', |
|
| 172 |
+ src: '{,*/}*.css',
|
|
| 173 |
+ dest: '.tmp/styles/' |
|
| 174 |
+ }] |
|
| 175 |
+ } |
|
| 176 |
+ }, |
|
| 177 |
+ |
|
| 178 |
+ // Automatically inject Bower components into the app |
|
| 179 |
+ wiredep: {
|
|
| 180 |
+ app: {
|
|
| 181 |
+ src: ['<%= yeoman.app %>/index.html'], |
|
| 182 |
+ ignorePath: /\.\.\// |
|
| 183 |
+ }, |
|
| 184 |
+ test: {
|
|
| 185 |
+ devDependencies: true, |
|
| 186 |
+ src: '<%= karma.unit.configFile %>', |
|
| 187 |
+ ignorePath: /\.\.\//, |
|
| 188 |
+ fileTypes:{
|
|
| 189 |
+ js: {
|
|
| 190 |
+ block: /(([\s\t]*)\/{2}\s*?bower:\s*?(\S*))(\n|\r|.)*?(\/{2}\s*endbower)/gi,
|
|
| 191 |
+ detect: {
|
|
| 192 |
+ js: /'(.*\.js)'/gi |
|
| 193 |
+ }, |
|
| 194 |
+ replace: {
|
|
| 195 |
+ js: '\'{{filePath}}\','
|
|
| 196 |
+ } |
|
| 197 |
+ } |
|
| 198 |
+ } |
|
| 199 |
+ } |
|
| 200 |
+ }, |
|
| 201 |
+ |
|
| 202 |
+ // Renames files for browser caching purposes |
|
| 203 |
+ filerev: {
|
|
| 204 |
+ dist: {
|
|
| 205 |
+ src: [ |
|
| 206 |
+ '<%= yeoman.dist %>/scripts/{,*/}*.js',
|
|
| 207 |
+ '<%= yeoman.dist %>/styles/{,*/}*.css',
|
|
| 208 |
+ '<%= yeoman.dist %>/images/{,*/}*.{png,jpg,jpeg,gif,webp,svg}',
|
|
| 209 |
+ '<%= yeoman.dist %>/styles/fonts/*' |
|
| 210 |
+ ] |
|
| 211 |
+ } |
|
| 212 |
+ }, |
|
| 213 |
+ |
|
| 214 |
+ // Reads HTML for usemin blocks to enable smart builds that automatically |
|
| 215 |
+ // concat, minify and revision files. Creates configurations in memory so |
|
| 216 |
+ // additional tasks can operate on them |
|
| 217 |
+ useminPrepare: {
|
|
| 218 |
+ html: '<%= yeoman.app %>/index.html', |
|
| 219 |
+ options: {
|
|
| 220 |
+ dest: '<%= yeoman.dist %>', |
|
| 221 |
+ flow: {
|
|
| 222 |
+ html: {
|
|
| 223 |
+ steps: {
|
|
| 224 |
+ js: ['concat', 'uglifyjs'], |
|
| 225 |
+ css: ['cssmin'] |
|
| 226 |
+ }, |
|
| 227 |
+ post: {}
|
|
| 228 |
+ } |
|
| 229 |
+ } |
|
| 230 |
+ } |
|
| 231 |
+ }, |
|
| 232 |
+ |
|
| 233 |
+ // Performs rewrites based on filerev and the useminPrepare configuration |
|
| 234 |
+ usemin: {
|
|
| 235 |
+ html: ['<%= yeoman.dist %>/{,*/}*.html'],
|
|
| 236 |
+ css: ['<%= yeoman.dist %>/styles/{,*/}*.css'],
|
|
| 237 |
+ options: {
|
|
| 238 |
+ assetsDirs: [ |
|
| 239 |
+ '<%= yeoman.dist %>', |
|
| 240 |
+ '<%= yeoman.dist %>/images', |
|
| 241 |
+ '<%= yeoman.dist %>/styles' |
|
| 242 |
+ ] |
|
| 243 |
+ } |
|
| 244 |
+ }, |
|
| 245 |
+ |
|
| 246 |
+ // The following *-min tasks will produce minified files in the dist folder |
|
| 247 |
+ // By default, your `index.html`'s <!-- Usemin block --> will take care of |
|
| 248 |
+ // minification. These next options are pre-configured if you do not wish |
|
| 249 |
+ // to use the Usemin blocks. |
|
| 250 |
+ // cssmin: {
|
|
| 251 |
+ // dist: {
|
|
| 252 |
+ // files: {
|
|
| 253 |
+ // '<%= yeoman.dist %>/styles/main.css': [ |
|
| 254 |
+ // '.tmp/styles/{,*/}*.css'
|
|
| 255 |
+ // ] |
|
| 256 |
+ // } |
|
| 257 |
+ // } |
|
| 258 |
+ // }, |
|
| 259 |
+ // uglify: {
|
|
| 260 |
+ // dist: {
|
|
| 261 |
+ // files: {
|
|
| 262 |
+ // '<%= yeoman.dist %>/scripts/scripts.js': [ |
|
| 263 |
+ // '<%= yeoman.dist %>/scripts/scripts.js' |
|
| 264 |
+ // ] |
|
| 265 |
+ // } |
|
| 266 |
+ // } |
|
| 267 |
+ // }, |
|
| 268 |
+ // concat: {
|
|
| 269 |
+ // dist: {}
|
|
| 270 |
+ // }, |
|
| 271 |
+ |
|
| 272 |
+ imagemin: {
|
|
| 273 |
+ dist: {
|
|
| 274 |
+ files: [{
|
|
| 275 |
+ expand: true, |
|
| 276 |
+ cwd: '<%= yeoman.app %>/images', |
|
| 277 |
+ src: '{,*/}*.{png,jpg,jpeg,gif}',
|
|
| 278 |
+ dest: '<%= yeoman.dist %>/images' |
|
| 279 |
+ }] |
|
| 280 |
+ } |
|
| 281 |
+ }, |
|
| 282 |
+ |
|
| 283 |
+ svgmin: {
|
|
| 284 |
+ dist: {
|
|
| 285 |
+ files: [{
|
|
| 286 |
+ expand: true, |
|
| 287 |
+ cwd: '<%= yeoman.app %>/images', |
|
| 288 |
+ src: '{,*/}*.svg',
|
|
| 289 |
+ dest: '<%= yeoman.dist %>/images' |
|
| 290 |
+ }] |
|
| 291 |
+ } |
|
| 292 |
+ }, |
|
| 293 |
+ |
|
| 294 |
+ htmlmin: {
|
|
| 295 |
+ dist: {
|
|
| 296 |
+ options: {
|
|
| 297 |
+ collapseWhitespace: true, |
|
| 298 |
+ conservativeCollapse: true, |
|
| 299 |
+ collapseBooleanAttributes: true, |
|
| 300 |
+ removeCommentsFromCDATA: true, |
|
| 301 |
+ removeOptionalTags: true |
|
| 302 |
+ }, |
|
| 303 |
+ files: [{
|
|
| 304 |
+ expand: true, |
|
| 305 |
+ cwd: '<%= yeoman.dist %>', |
|
| 306 |
+ src: ['*.html', 'views/{,*/}*.html'],
|
|
| 307 |
+ dest: '<%= yeoman.dist %>' |
|
| 308 |
+ }] |
|
| 309 |
+ } |
|
| 310 |
+ }, |
|
| 311 |
+ |
|
| 312 |
+ // ng-annotate tries to make the code safe for minification automatically |
|
| 313 |
+ // by using the Angular long form for dependency injection. |
|
| 314 |
+ ngAnnotate: {
|
|
| 315 |
+ dist: {
|
|
| 316 |
+ files: [{
|
|
| 317 |
+ expand: true, |
|
| 318 |
+ cwd: '.tmp/concat/scripts', |
|
| 319 |
+ src: '*.js', |
|
| 320 |
+ dest: '.tmp/concat/scripts' |
|
| 321 |
+ }] |
|
| 322 |
+ } |
|
| 323 |
+ }, |
|
| 324 |
+ |
|
| 325 |
+ // Replace Google CDN references |
|
| 326 |
+ cdnify: {
|
|
| 327 |
+ dist: {
|
|
| 328 |
+ html: ['<%= yeoman.dist %>/*.html'] |
|
| 329 |
+ } |
|
| 330 |
+ }, |
|
| 331 |
+ |
|
| 332 |
+ // Copies remaining files to places other tasks can use |
|
| 333 |
+ copy: {
|
|
| 334 |
+ dist: {
|
|
| 335 |
+ files: [{
|
|
| 336 |
+ expand: true, |
|
| 337 |
+ dot: true, |
|
| 338 |
+ cwd: '<%= yeoman.app %>', |
|
| 339 |
+ dest: '<%= yeoman.dist %>', |
|
| 340 |
+ src: [ |
|
| 341 |
+ '*.{ico,png,txt}',
|
|
| 342 |
+ '.htaccess', |
|
| 343 |
+ '*.html', |
|
| 344 |
+ 'views/{,*/}*.html',
|
|
| 345 |
+ 'images/{,*/}*.{webp}',
|
|
| 346 |
+ 'styles/fonts/{,*/}*.*'
|
|
| 347 |
+ ] |
|
| 348 |
+ }, {
|
|
| 349 |
+ expand: true, |
|
| 350 |
+ cwd: '.tmp/images', |
|
| 351 |
+ dest: '<%= yeoman.dist %>/images', |
|
| 352 |
+ src: ['generated/*'] |
|
| 353 |
+ }, {
|
|
| 354 |
+ expand: true, |
|
| 355 |
+ cwd: 'bower_components/bootstrap/dist', |
|
| 356 |
+ src: 'fonts/*', |
|
| 357 |
+ dest: '<%= yeoman.dist %>' |
|
| 358 |
+ }] |
|
| 359 |
+ }, |
|
| 360 |
+ styles: {
|
|
| 361 |
+ expand: true, |
|
| 362 |
+ cwd: '<%= yeoman.app %>/styles', |
|
| 363 |
+ dest: '.tmp/styles/', |
|
| 364 |
+ src: '{,*/}*.css'
|
|
| 365 |
+ } |
|
| 366 |
+ }, |
|
| 367 |
+ |
|
| 368 |
+ // Run some tasks in parallel to speed up the build process |
|
| 369 |
+ concurrent: {
|
|
| 370 |
+ server: [ |
|
| 371 |
+ 'copy:styles' |
|
| 372 |
+ ], |
|
| 373 |
+ test: [ |
|
| 374 |
+ 'copy:styles' |
|
| 375 |
+ ], |
|
| 376 |
+ dist: [ |
|
| 377 |
+ 'copy:styles', |
|
| 378 |
+ 'imagemin', |
|
| 379 |
+ 'svgmin' |
|
| 380 |
+ ] |
|
| 381 |
+ }, |
|
| 382 |
+ |
|
| 383 |
+ // Test settings |
|
| 384 |
+ karma: {
|
|
| 385 |
+ unit: {
|
|
| 386 |
+ configFile: 'test/karma.conf.js', |
|
| 387 |
+ singleRun: true |
|
| 388 |
+ } |
|
| 389 |
+ } |
|
| 390 |
+ }); |
|
| 391 |
+ |
|
| 392 |
+ |
|
| 393 |
+ grunt.registerTask('serve', 'Compile then start a connect web server', function (target) {
|
|
| 394 |
+ if (target === 'dist') {
|
|
| 395 |
+ return grunt.task.run(['build', 'connect:dist:keepalive']); |
|
| 396 |
+ } |
|
| 397 |
+ |
|
| 398 |
+ grunt.task.run([ |
|
| 399 |
+ 'clean:server', |
|
| 400 |
+ 'wiredep', |
|
| 401 |
+ 'concurrent:server', |
|
| 402 |
+ 'autoprefixer:server', |
|
| 403 |
+ 'connect:livereload', |
|
| 404 |
+ 'watch' |
|
| 405 |
+ ]); |
|
| 406 |
+ }); |
|
| 407 |
+ |
|
| 408 |
+ grunt.registerTask('server', 'DEPRECATED TASK. Use the "serve" task instead', function (target) {
|
|
| 409 |
+ grunt.log.warn('The `server` task has been deprecated. Use `grunt serve` to start a server.');
|
|
| 410 |
+ grunt.task.run(['serve:' + target]); |
|
| 411 |
+ }); |
|
| 412 |
+ |
|
| 413 |
+ grunt.registerTask('test', [
|
|
| 414 |
+ 'clean:server', |
|
| 415 |
+ 'wiredep', |
|
| 416 |
+ 'concurrent:test', |
|
| 417 |
+ 'autoprefixer', |
|
| 418 |
+ 'connect:test', |
|
| 419 |
+ 'karma' |
|
| 420 |
+ ]); |
|
| 421 |
+ |
|
| 422 |
+ grunt.registerTask('build', [
|
|
| 423 |
+ 'clean:dist', |
|
| 424 |
+ 'wiredep', |
|
| 425 |
+ 'useminPrepare', |
|
| 426 |
+ 'concurrent:dist', |
|
| 427 |
+ 'autoprefixer', |
|
| 428 |
+ 'concat', |
|
| 429 |
+ 'ngAnnotate', |
|
| 430 |
+ 'copy:dist', |
|
| 431 |
+ 'cdnify', |
|
| 432 |
+ 'cssmin', |
|
| 433 |
+ 'uglify', |
|
| 434 |
+ 'filerev', |
|
| 435 |
+ 'usemin', |
|
| 436 |
+ 'htmlmin' |
|
| 437 |
+ ]); |
|
| 438 |
+ |
|
| 439 |
+ grunt.registerTask('default', [
|
|
| 440 |
+ 'newer:jshint', |
|
| 441 |
+ 'test', |
|
| 442 |
+ 'build' |
|
| 443 |
+ ]); |
|
| 444 |
+}; |
@@ -0,0 +1,12 @@ |
||
| 1 |
+# domain-manager |
|
| 2 |
+ |
|
| 3 |
+This project is generated with [yo angular generator](https://github.com/yeoman/generator-angular) |
|
| 4 |
+version 0.11.1. |
|
| 5 |
+ |
|
| 6 |
+## Build & development |
|
| 7 |
+ |
|
| 8 |
+Run `grunt` for building and `grunt serve` for preview. |
|
| 9 |
+ |
|
| 10 |
+## Testing |
|
| 11 |
+ |
|
| 12 |
+Running `grunt test` will run the unit tests with karma. |
@@ -0,0 +1 @@ |
||
| 1 |
+*.coffee |
@@ -0,0 +1,543 @@ |
||
| 1 |
+# Apache Configuration File |
|
| 2 |
+ |
|
| 3 |
+# (!) Using `.htaccess` files slows down Apache, therefore, if you have access |
|
| 4 |
+# to the main server config file (usually called `httpd.conf`), you should add |
|
| 5 |
+# this logic there: http://httpd.apache.org/docs/current/howto/htaccess.html. |
|
| 6 |
+ |
|
| 7 |
+# ############################################################################## |
|
| 8 |
+# # CROSS-ORIGIN RESOURCE SHARING (CORS) # |
|
| 9 |
+# ############################################################################## |
|
| 10 |
+ |
|
| 11 |
+# ------------------------------------------------------------------------------ |
|
| 12 |
+# | Cross-domain AJAX requests | |
|
| 13 |
+# ------------------------------------------------------------------------------ |
|
| 14 |
+ |
|
| 15 |
+# Enable cross-origin AJAX requests. |
|
| 16 |
+# http://code.google.com/p/html5security/wiki/CrossOriginRequestSecurity |
|
| 17 |
+# http://enable-cors.org/ |
|
| 18 |
+ |
|
| 19 |
+# <IfModule mod_headers.c> |
|
| 20 |
+# Header set Access-Control-Allow-Origin "*" |
|
| 21 |
+# </IfModule> |
|
| 22 |
+ |
|
| 23 |
+# ------------------------------------------------------------------------------ |
|
| 24 |
+# | CORS-enabled images | |
|
| 25 |
+# ------------------------------------------------------------------------------ |
|
| 26 |
+ |
|
| 27 |
+# Send the CORS header for images when browsers request it. |
|
| 28 |
+# https://developer.mozilla.org/en/CORS_Enabled_Image |
|
| 29 |
+# http://blog.chromium.org/2011/07/using-cross-domain-images-in-webgl-and.html |
|
| 30 |
+# http://hacks.mozilla.org/2011/11/using-cors-to-load-webgl-textures-from-cross-domain-images/ |
|
| 31 |
+ |
|
| 32 |
+<IfModule mod_setenvif.c> |
|
| 33 |
+ <IfModule mod_headers.c> |
|
| 34 |
+ <FilesMatch "\.(gif|ico|jpe?g|png|svg|svgz|webp)$"> |
|
| 35 |
+ SetEnvIf Origin ":" IS_CORS |
|
| 36 |
+ Header set Access-Control-Allow-Origin "*" env=IS_CORS |
|
| 37 |
+ </FilesMatch> |
|
| 38 |
+ </IfModule> |
|
| 39 |
+</IfModule> |
|
| 40 |
+ |
|
| 41 |
+# ------------------------------------------------------------------------------ |
|
| 42 |
+# | Web fonts access | |
|
| 43 |
+# ------------------------------------------------------------------------------ |
|
| 44 |
+ |
|
| 45 |
+# Allow access from all domains for web fonts |
|
| 46 |
+ |
|
| 47 |
+<IfModule mod_headers.c> |
|
| 48 |
+ <FilesMatch "\.(eot|font.css|otf|ttc|ttf|woff)$"> |
|
| 49 |
+ Header set Access-Control-Allow-Origin "*" |
|
| 50 |
+ </FilesMatch> |
|
| 51 |
+</IfModule> |
|
| 52 |
+ |
|
| 53 |
+ |
|
| 54 |
+# ############################################################################## |
|
| 55 |
+# # ERRORS # |
|
| 56 |
+# ############################################################################## |
|
| 57 |
+ |
|
| 58 |
+# ------------------------------------------------------------------------------ |
|
| 59 |
+# | 404 error prevention for non-existing redirected folders | |
|
| 60 |
+# ------------------------------------------------------------------------------ |
|
| 61 |
+ |
|
| 62 |
+# Prevent Apache from returning a 404 error for a rewrite if a directory |
|
| 63 |
+# with the same name does not exist. |
|
| 64 |
+# http://httpd.apache.org/docs/current/content-negotiation.html#multiviews |
|
| 65 |
+# http://www.webmasterworld.com/apache/3808792.htm |
|
| 66 |
+ |
|
| 67 |
+Options -MultiViews |
|
| 68 |
+ |
|
| 69 |
+# ------------------------------------------------------------------------------ |
|
| 70 |
+# | Custom error messages / pages | |
|
| 71 |
+# ------------------------------------------------------------------------------ |
|
| 72 |
+ |
|
| 73 |
+# You can customize what Apache returns to the client in case of an error (see |
|
| 74 |
+# http://httpd.apache.org/docs/current/mod/core.html#errordocument), e.g.: |
|
| 75 |
+ |
|
| 76 |
+ErrorDocument 404 /404.html |
|
| 77 |
+ |
|
| 78 |
+ |
|
| 79 |
+# ############################################################################## |
|
| 80 |
+# # INTERNET EXPLORER # |
|
| 81 |
+# ############################################################################## |
|
| 82 |
+ |
|
| 83 |
+# ------------------------------------------------------------------------------ |
|
| 84 |
+# | Better website experience | |
|
| 85 |
+# ------------------------------------------------------------------------------ |
|
| 86 |
+ |
|
| 87 |
+# Force IE to render pages in the highest available mode in the various |
|
| 88 |
+# cases when it may not: http://hsivonen.iki.fi/doctype/ie-mode.pdf. |
|
| 89 |
+ |
|
| 90 |
+<IfModule mod_headers.c> |
|
| 91 |
+ Header set X-UA-Compatible "IE=edge" |
|
| 92 |
+ # `mod_headers` can't match based on the content-type, however, we only |
|
| 93 |
+ # want to send this header for HTML pages and not for the other resources |
|
| 94 |
+ <FilesMatch "\.(appcache|crx|css|eot|gif|htc|ico|jpe?g|js|m4a|m4v|manifest|mp4|oex|oga|ogg|ogv|otf|pdf|png|safariextz|svg|svgz|ttf|vcf|webapp|webm|webp|woff|xml|xpi)$"> |
|
| 95 |
+ Header unset X-UA-Compatible |
|
| 96 |
+ </FilesMatch> |
|
| 97 |
+</IfModule> |
|
| 98 |
+ |
|
| 99 |
+# ------------------------------------------------------------------------------ |
|
| 100 |
+# | Cookie setting from iframes | |
|
| 101 |
+# ------------------------------------------------------------------------------ |
|
| 102 |
+ |
|
| 103 |
+# Allow cookies to be set from iframes in IE. |
|
| 104 |
+ |
|
| 105 |
+# <IfModule mod_headers.c> |
|
| 106 |
+# Header set P3P "policyref=\"/w3c/p3p.xml\", CP=\"IDC DSP COR ADM DEVi TAIi PSA PSD IVAi IVDi CONi HIS OUR IND CNT\"" |
|
| 107 |
+# </IfModule> |
|
| 108 |
+ |
|
| 109 |
+# ------------------------------------------------------------------------------ |
|
| 110 |
+# | Screen flicker | |
|
| 111 |
+# ------------------------------------------------------------------------------ |
|
| 112 |
+ |
|
| 113 |
+# Stop screen flicker in IE on CSS rollovers (this only works in |
|
| 114 |
+# combination with the `ExpiresByType` directives for images from below). |
|
| 115 |
+ |
|
| 116 |
+# BrowserMatch "MSIE" brokenvary=1 |
|
| 117 |
+# BrowserMatch "Mozilla/4.[0-9]{2}" brokenvary=1
|
|
| 118 |
+# BrowserMatch "Opera" !brokenvary |
|
| 119 |
+# SetEnvIf brokenvary 1 force-no-vary |
|
| 120 |
+ |
|
| 121 |
+ |
|
| 122 |
+# ############################################################################## |
|
| 123 |
+# # MIME TYPES AND ENCODING # |
|
| 124 |
+# ############################################################################## |
|
| 125 |
+ |
|
| 126 |
+# ------------------------------------------------------------------------------ |
|
| 127 |
+# | Proper MIME types for all files | |
|
| 128 |
+# ------------------------------------------------------------------------------ |
|
| 129 |
+ |
|
| 130 |
+<IfModule mod_mime.c> |
|
| 131 |
+ |
|
| 132 |
+ # Audio |
|
| 133 |
+ AddType audio/mp4 m4a f4a f4b |
|
| 134 |
+ AddType audio/ogg oga ogg |
|
| 135 |
+ |
|
| 136 |
+ # JavaScript |
|
| 137 |
+ # Normalize to standard type (it's sniffed in IE anyways): |
|
| 138 |
+ # http://tools.ietf.org/html/rfc4329#section-7.2 |
|
| 139 |
+ AddType application/javascript js jsonp |
|
| 140 |
+ AddType application/json json |
|
| 141 |
+ |
|
| 142 |
+ # Video |
|
| 143 |
+ AddType video/mp4 mp4 m4v f4v f4p |
|
| 144 |
+ AddType video/ogg ogv |
|
| 145 |
+ AddType video/webm webm |
|
| 146 |
+ AddType video/x-flv flv |
|
| 147 |
+ |
|
| 148 |
+ # Web fonts |
|
| 149 |
+ AddType application/font-woff woff |
|
| 150 |
+ AddType application/vnd.ms-fontobject eot |
|
| 151 |
+ |
|
| 152 |
+ # Browsers usually ignore the font MIME types and sniff the content, |
|
| 153 |
+ # however, Chrome shows a warning if other MIME types are used for the |
|
| 154 |
+ # following fonts. |
|
| 155 |
+ AddType application/x-font-ttf ttc ttf |
|
| 156 |
+ AddType font/opentype otf |
|
| 157 |
+ |
|
| 158 |
+ # Make SVGZ fonts work on iPad: |
|
| 159 |
+ # https://twitter.com/FontSquirrel/status/14855840545 |
|
| 160 |
+ AddType image/svg+xml svg svgz |
|
| 161 |
+ AddEncoding gzip svgz |
|
| 162 |
+ |
|
| 163 |
+ # Other |
|
| 164 |
+ AddType application/octet-stream safariextz |
|
| 165 |
+ AddType application/x-chrome-extension crx |
|
| 166 |
+ AddType application/x-opera-extension oex |
|
| 167 |
+ AddType application/x-shockwave-flash swf |
|
| 168 |
+ AddType application/x-web-app-manifest+json webapp |
|
| 169 |
+ AddType application/x-xpinstall xpi |
|
| 170 |
+ AddType application/xml atom rdf rss xml |
|
| 171 |
+ AddType image/webp webp |
|
| 172 |
+ AddType image/x-icon ico |
|
| 173 |
+ AddType text/cache-manifest appcache manifest |
|
| 174 |
+ AddType text/vtt vtt |
|
| 175 |
+ AddType text/x-component htc |
|
| 176 |
+ AddType text/x-vcard vcf |
|
| 177 |
+ |
|
| 178 |
+</IfModule> |
|
| 179 |
+ |
|
| 180 |
+# ------------------------------------------------------------------------------ |
|
| 181 |
+# | UTF-8 encoding | |
|
| 182 |
+# ------------------------------------------------------------------------------ |
|
| 183 |
+ |
|
| 184 |
+# Use UTF-8 encoding for anything served as `text/html` or `text/plain`. |
|
| 185 |
+AddDefaultCharset utf-8 |
|
| 186 |
+ |
|
| 187 |
+# Force UTF-8 for certain file formats. |
|
| 188 |
+<IfModule mod_mime.c> |
|
| 189 |
+ AddCharset utf-8 .atom .css .js .json .rss .vtt .webapp .xml |
|
| 190 |
+</IfModule> |
|
| 191 |
+ |
|
| 192 |
+ |
|
| 193 |
+# ############################################################################## |
|
| 194 |
+# # URL REWRITES # |
|
| 195 |
+# ############################################################################## |
|
| 196 |
+ |
|
| 197 |
+# ------------------------------------------------------------------------------ |
|
| 198 |
+# | Rewrite engine | |
|
| 199 |
+# ------------------------------------------------------------------------------ |
|
| 200 |
+ |
|
| 201 |
+# Turning on the rewrite engine and enabling the `FollowSymLinks` option is |
|
| 202 |
+# necessary for the following directives to work. |
|
| 203 |
+ |
|
| 204 |
+# If your web host doesn't allow the `FollowSymlinks` option, you may need to |
|
| 205 |
+# comment it out and use `Options +SymLinksIfOwnerMatch` but, be aware of the |
|
| 206 |
+# performance impact: http://httpd.apache.org/docs/current/misc/perf-tuning.html#symlinks |
|
| 207 |
+ |
|
| 208 |
+# Also, some cloud hosting services require `RewriteBase` to be set: |
|
| 209 |
+# http://www.rackspace.com/knowledge_center/frequently-asked-question/why-is-mod-rewrite-not-working-on-my-site |
|
| 210 |
+ |
|
| 211 |
+<IfModule mod_rewrite.c> |
|
| 212 |
+ Options +FollowSymlinks |
|
| 213 |
+ # Options +SymLinksIfOwnerMatch |
|
| 214 |
+ RewriteEngine On |
|
| 215 |
+ # RewriteBase / |
|
| 216 |
+</IfModule> |
|
| 217 |
+ |
|
| 218 |
+# ------------------------------------------------------------------------------ |
|
| 219 |
+# | Suppressing / Forcing the "www." at the beginning of URLs | |
|
| 220 |
+# ------------------------------------------------------------------------------ |
|
| 221 |
+ |
|
| 222 |
+# The same content should never be available under two different URLs especially |
|
| 223 |
+# not with and without "www." at the beginning. This can cause SEO problems |
|
| 224 |
+# (duplicate content), therefore, you should choose one of the alternatives and |
|
| 225 |
+# redirect the other one. |
|
| 226 |
+ |
|
| 227 |
+# By default option 1 (no "www.") is activated: |
|
| 228 |
+# http://no-www.org/faq.php?q=class_b |
|
| 229 |
+ |
|
| 230 |
+# If you'd prefer to use option 2, just comment out all the lines from option 1 |
|
| 231 |
+# and uncomment the ones from option 2. |
|
| 232 |
+ |
|
| 233 |
+# IMPORTANT: NEVER USE BOTH RULES AT THE SAME TIME! |
|
| 234 |
+ |
|
| 235 |
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - |
|
| 236 |
+ |
|
| 237 |
+# Option 1: rewrite www.example.com → example.com |
|
| 238 |
+ |
|
| 239 |
+<IfModule mod_rewrite.c> |
|
| 240 |
+ RewriteCond %{HTTPS} !=on
|
|
| 241 |
+ RewriteCond %{HTTP_HOST} ^www\.(.+)$ [NC]
|
|
| 242 |
+ RewriteRule ^ http://%1%{REQUEST_URI} [R=301,L]
|
|
| 243 |
+</IfModule> |
|
| 244 |
+ |
|
| 245 |
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - |
|
| 246 |
+ |
|
| 247 |
+# Option 2: rewrite example.com → www.example.com |
|
| 248 |
+ |
|
| 249 |
+# Be aware that the following might not be a good idea if you use "real" |
|
| 250 |
+# subdomains for certain parts of your website. |
|
| 251 |
+ |
|
| 252 |
+# <IfModule mod_rewrite.c> |
|
| 253 |
+# RewriteCond %{HTTPS} !=on
|
|
| 254 |
+# RewriteCond %{HTTP_HOST} !^www\..+$ [NC]
|
|
| 255 |
+# RewriteRule ^ http://www.%{HTTP_HOST}%{REQUEST_URI} [R=301,L]
|
|
| 256 |
+# </IfModule> |
|
| 257 |
+ |
|
| 258 |
+ |
|
| 259 |
+# ############################################################################## |
|
| 260 |
+# # SECURITY # |
|
| 261 |
+# ############################################################################## |
|
| 262 |
+ |
|
| 263 |
+# ------------------------------------------------------------------------------ |
|
| 264 |
+# | Content Security Policy (CSP) | |
|
| 265 |
+# ------------------------------------------------------------------------------ |
|
| 266 |
+ |
|
| 267 |
+# You can mitigate the risk of cross-site scripting and other content-injection |
|
| 268 |
+# attacks by setting a Content Security Policy which whitelists trusted sources |
|
| 269 |
+# of content for your site. |
|
| 270 |
+ |
|
| 271 |
+# The example header below allows ONLY scripts that are loaded from the current |
|
| 272 |
+# site's origin (no inline scripts, no CDN, etc). This almost certainly won't |
|
| 273 |
+# work as-is for your site! |
|
| 274 |
+ |
|
| 275 |
+# To get all the details you'll need to craft a reasonable policy for your site, |
|
| 276 |
+# read: http://html5rocks.com/en/tutorials/security/content-security-policy (or |
|
| 277 |
+# see the specification: http://w3.org/TR/CSP). |
|
| 278 |
+ |
|
| 279 |
+# <IfModule mod_headers.c> |
|
| 280 |
+# Header set Content-Security-Policy "script-src 'self'; object-src 'self'" |
|
| 281 |
+# <FilesMatch "\.(appcache|crx|css|eot|gif|htc|ico|jpe?g|js|m4a|m4v|manifest|mp4|oex|oga|ogg|ogv|otf|pdf|png|safariextz|svg|svgz|ttf|vcf|webapp|webm|webp|woff|xml|xpi)$"> |
|
| 282 |
+# Header unset Content-Security-Policy |
|
| 283 |
+# </FilesMatch> |
|
| 284 |
+# </IfModule> |
|
| 285 |
+ |
|
| 286 |
+# ------------------------------------------------------------------------------ |
|
| 287 |
+# | File access | |
|
| 288 |
+# ------------------------------------------------------------------------------ |
|
| 289 |
+ |
|
| 290 |
+# Block access to directories without a default document. |
|
| 291 |
+# Usually you should leave this uncommented because you shouldn't allow anyone |
|
| 292 |
+# to surf through every directory on your server (which may includes rather |
|
| 293 |
+# private places like the CMS's directories). |
|
| 294 |
+ |
|
| 295 |
+<IfModule mod_autoindex.c> |
|
| 296 |
+ Options -Indexes |
|
| 297 |
+</IfModule> |
|
| 298 |
+ |
|
| 299 |
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - |
|
| 300 |
+ |
|
| 301 |
+# Block access to hidden files and directories. |
|
| 302 |
+# This includes directories used by version control systems such as Git and SVN. |
|
| 303 |
+ |
|
| 304 |
+<IfModule mod_rewrite.c> |
|
| 305 |
+ RewriteCond %{SCRIPT_FILENAME} -d [OR]
|
|
| 306 |
+ RewriteCond %{SCRIPT_FILENAME} -f
|
|
| 307 |
+ RewriteRule "(^|/)\." - [F] |
|
| 308 |
+</IfModule> |
|
| 309 |
+ |
|
| 310 |
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - |
|
| 311 |
+ |
|
| 312 |
+# Block access to backup and source files. |
|
| 313 |
+# These files may be left by some text editors and can pose a great security |
|
| 314 |
+# danger when anyone has access to them. |
|
| 315 |
+ |
|
| 316 |
+<FilesMatch "(^#.*#|\.(bak|config|dist|fla|inc|ini|log|psd|sh|sql|sw[op])|~)$"> |
|
| 317 |
+ Order allow,deny |
|
| 318 |
+ Deny from all |
|
| 319 |
+ Satisfy All |
|
| 320 |
+</FilesMatch> |
|
| 321 |
+ |
|
| 322 |
+# ------------------------------------------------------------------------------ |
|
| 323 |
+# | Secure Sockets Layer (SSL) | |
|
| 324 |
+# ------------------------------------------------------------------------------ |
|
| 325 |
+ |
|
| 326 |
+# Rewrite secure requests properly to prevent SSL certificate warnings, e.g.: |
|
| 327 |
+# prevent `https://www.example.com` when your certificate only allows |
|
| 328 |
+# `https://secure.example.com`. |
|
| 329 |
+ |
|
| 330 |
+# <IfModule mod_rewrite.c> |
|
| 331 |
+# RewriteCond %{SERVER_PORT} !^443
|
|
| 332 |
+# RewriteRule ^ https://example-domain-please-change-me.com%{REQUEST_URI} [R=301,L]
|
|
| 333 |
+# </IfModule> |
|
| 334 |
+ |
|
| 335 |
+# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - |
|
| 336 |
+ |
|
| 337 |
+# Force client-side SSL redirection. |
|
| 338 |
+ |
|
| 339 |
+# If a user types "example.com" in his browser, the above rule will redirect him |
|
| 340 |
+# to the secure version of the site. That still leaves a window of opportunity |
|
| 341 |
+# (the initial HTTP connection) for an attacker to downgrade or redirect the |
|
| 342 |
+# request. The following header ensures that browser will ONLY connect to your |
|
| 343 |
+# server via HTTPS, regardless of what the users type in the address bar. |
|
| 344 |
+# http://www.html5rocks.com/en/tutorials/security/transport-layer-security/ |
|
| 345 |
+ |
|
| 346 |
+# <IfModule mod_headers.c> |
|
| 347 |
+# Header set Strict-Transport-Security max-age=16070400; |
|
| 348 |
+# </IfModule> |
|
| 349 |
+ |
|
| 350 |
+# ------------------------------------------------------------------------------ |
|
| 351 |
+# | Server software information | |
|
| 352 |
+# ------------------------------------------------------------------------------ |
|
| 353 |
+ |
|
| 354 |
+# Avoid displaying the exact Apache version number, the description of the |
|
| 355 |
+# generic OS-type and the information about Apache's compiled-in modules. |
|
| 356 |
+ |
|
| 357 |
+# ADD THIS DIRECTIVE IN THE `httpd.conf` AS IT WILL NOT WORK IN THE `.htaccess`! |
|
| 358 |
+ |
|
| 359 |
+# ServerTokens Prod |
|
| 360 |
+ |
|
| 361 |
+ |
|
| 362 |
+# ############################################################################## |
|
| 363 |
+# # WEB PERFORMANCE # |
|
| 364 |
+# ############################################################################## |
|
| 365 |
+ |
|
| 366 |
+# ------------------------------------------------------------------------------ |
|
| 367 |
+# | Compression | |
|
| 368 |
+# ------------------------------------------------------------------------------ |
|
| 369 |
+ |
|
| 370 |
+<IfModule mod_deflate.c> |
|
| 371 |
+ |
|
| 372 |
+ # Force compression for mangled headers. |
|
| 373 |
+ # http://developer.yahoo.com/blogs/ydn/posts/2010/12/pushing-beyond-gzipping |
|
| 374 |
+ <IfModule mod_setenvif.c> |
|
| 375 |
+ <IfModule mod_headers.c> |
|
| 376 |
+ SetEnvIfNoCase ^(Accept-EncodXng|X-cept-Encoding|X{15}|~{15}|-{15})$ ^((gzip|deflate)\s*,?\s*)+|[X~-]{4,13}$ HAVE_Accept-Encoding
|
|
| 377 |
+ RequestHeader append Accept-Encoding "gzip,deflate" env=HAVE_Accept-Encoding |
|
| 378 |
+ </IfModule> |
|
| 379 |
+ </IfModule> |
|
| 380 |
+ |
|
| 381 |
+ # Compress all output labeled with one of the following MIME-types |
|
| 382 |
+ # (for Apache versions below 2.3.7, you don't need to enable `mod_filter` |
|
| 383 |
+ # and can remove the `<IfModule mod_filter.c>` and `</IfModule>` lines |
|
| 384 |
+ # as `AddOutputFilterByType` is still in the core directives). |
|
| 385 |
+ <IfModule mod_filter.c> |
|
| 386 |
+ AddOutputFilterByType DEFLATE application/atom+xml \ |
|
| 387 |
+ application/javascript \ |
|
| 388 |
+ application/json \ |
|
| 389 |
+ application/rss+xml \ |
|
| 390 |
+ application/vnd.ms-fontobject \ |
|
| 391 |
+ application/x-font-ttf \ |
|
| 392 |
+ application/x-web-app-manifest+json \ |
|
| 393 |
+ application/xhtml+xml \ |
|
| 394 |
+ application/xml \ |
|
| 395 |
+ font/opentype \ |
|
| 396 |
+ image/svg+xml \ |
|
| 397 |
+ image/x-icon \ |
|
| 398 |
+ text/css \ |
|
| 399 |
+ text/html \ |
|
| 400 |
+ text/plain \ |
|
| 401 |
+ text/x-component \ |
|
| 402 |
+ text/xml |
|
| 403 |
+ </IfModule> |
|
| 404 |
+ |
|
| 405 |
+</IfModule> |
|
| 406 |
+ |
|
| 407 |
+# ------------------------------------------------------------------------------ |
|
| 408 |
+# | Content transformations | |
|
| 409 |
+# ------------------------------------------------------------------------------ |
|
| 410 |
+ |
|
| 411 |
+# Prevent some of the mobile network providers from modifying the content of |
|
| 412 |
+# your site: http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.9.5. |
|
| 413 |
+ |
|
| 414 |
+# <IfModule mod_headers.c> |
|
| 415 |
+# Header set Cache-Control "no-transform" |
|
| 416 |
+# </IfModule> |
|
| 417 |
+ |
|
| 418 |
+# ------------------------------------------------------------------------------ |
|
| 419 |
+# | ETag removal | |
|
| 420 |
+# ------------------------------------------------------------------------------ |
|
| 421 |
+ |
|
| 422 |
+# Since we're sending far-future expires headers (see below), ETags can |
|
| 423 |
+# be removed: http://developer.yahoo.com/performance/rules.html#etags. |
|
| 424 |
+ |
|
| 425 |
+# `FileETag None` is not enough for every server. |
|
| 426 |
+<IfModule mod_headers.c> |
|
| 427 |
+ Header unset ETag |
|
| 428 |
+</IfModule> |
|
| 429 |
+ |
|
| 430 |
+FileETag None |
|
| 431 |
+ |
|
| 432 |
+# ------------------------------------------------------------------------------ |
|
| 433 |
+# | Expires headers (for better cache control) | |
|
| 434 |
+# ------------------------------------------------------------------------------ |
|
| 435 |
+ |
|
| 436 |
+# The following expires headers are set pretty far in the future. If you don't |
|
| 437 |
+# control versioning with filename-based cache busting, consider lowering the |
|
| 438 |
+# cache time for resources like CSS and JS to something like 1 week. |
|
| 439 |
+ |
|
| 440 |
+<IfModule mod_expires.c> |
|
| 441 |
+ |
|
| 442 |
+ ExpiresActive on |
|
| 443 |
+ ExpiresDefault "access plus 1 month" |
|
| 444 |
+ |
|
| 445 |
+ # CSS |
|
| 446 |
+ ExpiresByType text/css "access plus 1 year" |
|
| 447 |
+ |
|
| 448 |
+ # Data interchange |
|
| 449 |
+ ExpiresByType application/json "access plus 0 seconds" |
|
| 450 |
+ ExpiresByType application/xml "access plus 0 seconds" |
|
| 451 |
+ ExpiresByType text/xml "access plus 0 seconds" |
|
| 452 |
+ |
|
| 453 |
+ # Favicon (cannot be renamed!) |
|
| 454 |
+ ExpiresByType image/x-icon "access plus 1 week" |
|
| 455 |
+ |
|
| 456 |
+ # HTML components (HTCs) |
|
| 457 |
+ ExpiresByType text/x-component "access plus 1 month" |
|
| 458 |
+ |
|
| 459 |
+ # HTML |
|
| 460 |
+ ExpiresByType text/html "access plus 0 seconds" |
|
| 461 |
+ |
|
| 462 |
+ # JavaScript |
|
| 463 |
+ ExpiresByType application/javascript "access plus 1 year" |
|
| 464 |
+ |
|
| 465 |
+ # Manifest files |
|
| 466 |
+ ExpiresByType application/x-web-app-manifest+json "access plus 0 seconds" |
|
| 467 |
+ ExpiresByType text/cache-manifest "access plus 0 seconds" |
|
| 468 |
+ |
|
| 469 |
+ # Media |
|
| 470 |
+ ExpiresByType audio/ogg "access plus 1 month" |
|
| 471 |
+ ExpiresByType image/gif "access plus 1 month" |
|
| 472 |
+ ExpiresByType image/jpeg "access plus 1 month" |
|
| 473 |
+ ExpiresByType image/png "access plus 1 month" |
|
| 474 |
+ ExpiresByType video/mp4 "access plus 1 month" |
|
| 475 |
+ ExpiresByType video/ogg "access plus 1 month" |
|
| 476 |
+ ExpiresByType video/webm "access plus 1 month" |
|
| 477 |
+ |
|
| 478 |
+ # Web feeds |
|
| 479 |
+ ExpiresByType application/atom+xml "access plus 1 hour" |
|
| 480 |
+ ExpiresByType application/rss+xml "access plus 1 hour" |
|
| 481 |
+ |
|
| 482 |
+ # Web fonts |
|
| 483 |
+ ExpiresByType application/font-woff "access plus 1 month" |
|
| 484 |
+ ExpiresByType application/vnd.ms-fontobject "access plus 1 month" |
|
| 485 |
+ ExpiresByType application/x-font-ttf "access plus 1 month" |
|
| 486 |
+ ExpiresByType font/opentype "access plus 1 month" |
|
| 487 |
+ ExpiresByType image/svg+xml "access plus 1 month" |
|
| 488 |
+ |
|
| 489 |
+</IfModule> |
|
| 490 |
+ |
|
| 491 |
+# ------------------------------------------------------------------------------ |
|
| 492 |
+# | Filename-based cache busting | |
|
| 493 |
+# ------------------------------------------------------------------------------ |
|
| 494 |
+ |
|
| 495 |
+# If you're not using a build process to manage your filename version revving, |
|
| 496 |
+# you might want to consider enabling the following directives to route all |
|
| 497 |
+# requests such as `/css/style.12345.css` to `/css/style.css`. |
|
| 498 |
+ |
|
| 499 |
+# To understand why this is important and a better idea than `*.css?v231`, read: |
|
| 500 |
+# http://stevesouders.com/blog/2008/08/23/revving-filenames-dont-use-querystring |
|
| 501 |
+ |
|
| 502 |
+# <IfModule mod_rewrite.c> |
|
| 503 |
+# RewriteCond %{REQUEST_FILENAME} !-f
|
|
| 504 |
+# RewriteCond %{REQUEST_FILENAME} !-d
|
|
| 505 |
+# RewriteRule ^(.+)\.(\d+)\.(js|css|png|jpg|gif)$ $1.$3 [L] |
|
| 506 |
+# </IfModule> |
|
| 507 |
+ |
|
| 508 |
+# ------------------------------------------------------------------------------ |
|
| 509 |
+# | File concatenation | |
|
| 510 |
+# ------------------------------------------------------------------------------ |
|
| 511 |
+ |
|
| 512 |
+# Allow concatenation from within specific CSS and JS files, e.g.: |
|
| 513 |
+# Inside of `script.combined.js` you could have |
|
| 514 |
+# <!--#include file="libs/jquery.js" --> |
|
| 515 |
+# <!--#include file="plugins/jquery.idletimer.js" --> |
|
| 516 |
+# and they would be included into this single file. |
|
| 517 |
+ |
|
| 518 |
+# <IfModule mod_include.c> |
|
| 519 |
+# <FilesMatch "\.combined\.js$"> |
|
| 520 |
+# Options +Includes |
|
| 521 |
+# AddOutputFilterByType INCLUDES application/javascript application/json |
|
| 522 |
+# SetOutputFilter INCLUDES |
|
| 523 |
+# </FilesMatch> |
|
| 524 |
+# <FilesMatch "\.combined\.css$"> |
|
| 525 |
+# Options +Includes |
|
| 526 |
+# AddOutputFilterByType INCLUDES text/css |
|
| 527 |
+# SetOutputFilter INCLUDES |
|
| 528 |
+# </FilesMatch> |
|
| 529 |
+# </IfModule> |
|
| 530 |
+ |
|
| 531 |
+# ------------------------------------------------------------------------------ |
|
| 532 |
+# | Persistent connections | |
|
| 533 |
+# ------------------------------------------------------------------------------ |
|
| 534 |
+ |
|
| 535 |
+# Allow multiple requests to be sent over the same TCP connection: |
|
| 536 |
+# http://httpd.apache.org/docs/current/en/mod/core.html#keepalive. |
|
| 537 |
+ |
|
| 538 |
+# Enable if you serve a lot of static content but, be aware of the |
|
| 539 |
+# possible disadvantages! |
|
| 540 |
+ |
|
| 541 |
+# <IfModule mod_headers.c> |
|
| 542 |
+# Header set Connection Keep-Alive |
|
| 543 |
+# </IfModule> |
@@ -0,0 +1,157 @@ |
||
| 1 |
+<!doctype html> |
|
| 2 |
+<html lang="en"> |
|
| 3 |
+ <head> |
|
| 4 |
+ <meta charset="utf-8"> |
|
| 5 |
+ <title>Page Not Found :(</title> |
|
| 6 |
+ <style> |
|
| 7 |
+ ::-moz-selection {
|
|
| 8 |
+ background: #b3d4fc; |
|
| 9 |
+ text-shadow: none; |
|
| 10 |
+ } |
|
| 11 |
+ |
|
| 12 |
+ ::selection {
|
|
| 13 |
+ background: #b3d4fc; |
|
| 14 |
+ text-shadow: none; |
|
| 15 |
+ } |
|
| 16 |
+ |
|
| 17 |
+ html {
|
|
| 18 |
+ padding: 30px 10px; |
|
| 19 |
+ font-size: 20px; |
|
| 20 |
+ line-height: 1.4; |
|
| 21 |
+ color: #737373; |
|
| 22 |
+ background: #f0f0f0; |
|
| 23 |
+ -webkit-text-size-adjust: 100%; |
|
| 24 |
+ -ms-text-size-adjust: 100%; |
|
| 25 |
+ } |
|
| 26 |
+ |
|
| 27 |
+ html, |
|
| 28 |
+ input {
|
|
| 29 |
+ font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; |
|
| 30 |
+ } |
|
| 31 |
+ |
|
| 32 |
+ body {
|
|
| 33 |
+ max-width: 500px; |
|
| 34 |
+ _width: 500px; |
|
| 35 |
+ padding: 30px 20px 50px; |
|
| 36 |
+ border: 1px solid #b3b3b3; |
|
| 37 |
+ border-radius: 4px; |
|
| 38 |
+ margin: 0 auto; |
|
| 39 |
+ box-shadow: 0 1px 10px #a7a7a7, inset 0 1px 0 #fff; |
|
| 40 |
+ background: #fcfcfc; |
|
| 41 |
+ } |
|
| 42 |
+ |
|
| 43 |
+ h1 {
|
|
| 44 |
+ margin: 0 10px; |
|
| 45 |
+ font-size: 50px; |
|
| 46 |
+ text-align: center; |
|
| 47 |
+ } |
|
| 48 |
+ |
|
| 49 |
+ h1 span {
|
|
| 50 |
+ color: #bbb; |
|
| 51 |
+ } |
|
| 52 |
+ |
|
| 53 |
+ h3 {
|
|
| 54 |
+ margin: 1.5em 0 0.5em; |
|
| 55 |
+ } |
|
| 56 |
+ |
|
| 57 |
+ p {
|
|
| 58 |
+ margin: 1em 0; |
|
| 59 |
+ } |
|
| 60 |
+ |
|
| 61 |
+ ul {
|
|
| 62 |
+ padding: 0 0 0 40px; |
|
| 63 |
+ margin: 1em 0; |
|
| 64 |
+ } |
|
| 65 |
+ |
|
| 66 |
+ .container {
|
|
| 67 |
+ max-width: 380px; |
|
| 68 |
+ _width: 380px; |
|
| 69 |
+ margin: 0 auto; |
|
| 70 |
+ } |
|
| 71 |
+ |
|
| 72 |
+ /* google search */ |
|
| 73 |
+ |
|
| 74 |
+ #goog-fixurl ul {
|
|
| 75 |
+ list-style: none; |
|
| 76 |
+ padding: 0; |
|
| 77 |
+ margin: 0; |
|
| 78 |
+ } |
|
| 79 |
+ |
|
| 80 |
+ #goog-fixurl form {
|
|
| 81 |
+ margin: 0; |
|
| 82 |
+ } |
|
| 83 |
+ |
|
| 84 |
+ #goog-wm-qt, |
|
| 85 |
+ #goog-wm-sb {
|
|
| 86 |
+ border: 1px solid #bbb; |
|
| 87 |
+ font-size: 16px; |
|
| 88 |
+ line-height: normal; |
|
| 89 |
+ vertical-align: top; |
|
| 90 |
+ color: #444; |
|
| 91 |
+ border-radius: 2px; |
|
| 92 |
+ } |
|
| 93 |
+ |
|
| 94 |
+ #goog-wm-qt {
|
|
| 95 |
+ width: 220px; |
|
| 96 |
+ height: 20px; |
|
| 97 |
+ padding: 5px; |
|
| 98 |
+ margin: 5px 10px 0 0; |
|
| 99 |
+ box-shadow: inset 0 1px 1px #ccc; |
|
| 100 |
+ } |
|
| 101 |
+ |
|
| 102 |
+ #goog-wm-sb {
|
|
| 103 |
+ display: inline-block; |
|
| 104 |
+ height: 32px; |
|
| 105 |
+ padding: 0 10px; |
|
| 106 |
+ margin: 5px 0 0; |
|
| 107 |
+ white-space: nowrap; |
|
| 108 |
+ cursor: pointer; |
|
| 109 |
+ background-color: #f5f5f5; |
|
| 110 |
+ background-image: -webkit-linear-gradient(rgba(255,255,255,0), #f1f1f1); |
|
| 111 |
+ background-image: -moz-linear-gradient(rgba(255,255,255,0), #f1f1f1); |
|
| 112 |
+ background-image: -ms-linear-gradient(rgba(255,255,255,0), #f1f1f1); |
|
| 113 |
+ background-image: -o-linear-gradient(rgba(255,255,255,0), #f1f1f1); |
|
| 114 |
+ -webkit-appearance: none; |
|
| 115 |
+ -moz-appearance: none; |
|
| 116 |
+ appearance: none; |
|
| 117 |
+ *overflow: visible; |
|
| 118 |
+ *display: inline; |
|
| 119 |
+ *zoom: 1; |
|
| 120 |
+ } |
|
| 121 |
+ |
|
| 122 |
+ #goog-wm-sb:hover, |
|
| 123 |
+ #goog-wm-sb:focus {
|
|
| 124 |
+ border-color: #aaa; |
|
| 125 |
+ box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1); |
|
| 126 |
+ background-color: #f8f8f8; |
|
| 127 |
+ } |
|
| 128 |
+ |
|
| 129 |
+ #goog-wm-qt:hover, |
|
| 130 |
+ #goog-wm-qt:focus {
|
|
| 131 |
+ border-color: #105cb6; |
|
| 132 |
+ outline: 0; |
|
| 133 |
+ color: #222; |
|
| 134 |
+ } |
|
| 135 |
+ |
|
| 136 |
+ input::-moz-focus-inner {
|
|
| 137 |
+ padding: 0; |
|
| 138 |
+ border: 0; |
|
| 139 |
+ } |
|
| 140 |
+ </style> |
|
| 141 |
+ </head> |
|
| 142 |
+ <body> |
|
| 143 |
+ <div class="container"> |
|
| 144 |
+ <h1>Not found <span>:(</span></h1> |
|
| 145 |
+ <p>Sorry, but the page you were trying to view does not exist.</p> |
|
| 146 |
+ <p>It looks like this was the result of either:</p> |
|
| 147 |
+ <ul> |
|
| 148 |
+ <li>a mistyped address</li> |
|
| 149 |
+ <li>an out-of-date link</li> |
|
| 150 |
+ </ul> |
|
| 151 |
+ <script> |
|
| 152 |
+ var GOOG_FIXURL_LANG = (navigator.language || '').slice(0,2),GOOG_FIXURL_SITE = location.host; |
|
| 153 |
+ </script> |
|
| 154 |
+ <script src="//linkhelp.clients.google.com/tbproxy/lh/wm/fixurl.js"></script> |
|
| 155 |
+ </div> |
|
| 156 |
+ </body> |
|
| 157 |
+</html> |
@@ -0,0 +1,99 @@ |
||
| 1 |
+<!doctype html> |
|
| 2 |
+<html class="no-js"> |
|
| 3 |
+ <head> |
|
| 4 |
+ <meta charset="utf-8"> |
|
| 5 |
+ <title></title> |
|
| 6 |
+ <meta name="description" content=""> |
|
| 7 |
+ <meta name="viewport" content="width=device-width"> |
|
| 8 |
+ <!-- Place favicon.ico and apple-touch-icon.png in the root directory --> |
|
| 9 |
+ <!-- build:css(.) styles/vendor.css --> |
|
| 10 |
+ <!-- bower:css --> |
|
| 11 |
+ <link rel="stylesheet" href="bower_components/bootstrap/dist/css/bootstrap.css" /> |
|
| 12 |
+ <link rel="stylesheet" href="bower_components/ladda/dist/ladda.min.css" /> |
|
| 13 |
+ <!-- endbower --> |
|
| 14 |
+ <!-- endbuild --> |
|
| 15 |
+ <!-- build:css(.tmp) styles/main.css --> |
|
| 16 |
+ <link rel="stylesheet" href="styles/main.css"> |
|
| 17 |
+ <!-- endbuild --> |
|
| 18 |
+ </head> |
|
| 19 |
+ <body ng-app="domainManagerApp"> |
|
| 20 |
+ <!--[if lt IE 7]> |
|
| 21 |
+ <p class="browsehappy">You are using an <strong>outdated</strong> browser. Please <a href="http://browsehappy.com/">upgrade your browser</a> to improve your experience.</p> |
|
| 22 |
+ <![endif]--> |
|
| 23 |
+ |
|
| 24 |
+ <!-- Add your site or application content here --> |
|
| 25 |
+ <div class="header"> |
|
| 26 |
+ <div class="navbar navbar-default" role="navigation"> |
|
| 27 |
+ <div class="container"> |
|
| 28 |
+ <div class="navbar-header"> |
|
| 29 |
+ |
|
| 30 |
+ <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#js-navbar-collapse"> |
|
| 31 |
+ <span class="sr-only">Toggle navigation</span> |
|
| 32 |
+ <span class="icon-bar"></span> |
|
| 33 |
+ <span class="icon-bar"></span> |
|
| 34 |
+ <span class="icon-bar"></span> |
|
| 35 |
+ </button> |
|
| 36 |
+ |
|
| 37 |
+ <a class="navbar-brand" href="#/">domainManager</a> |
|
| 38 |
+ </div> |
|
| 39 |
+ |
|
| 40 |
+ <div class="collapse navbar-collapse" id="js-navbar-collapse" ng-controller="HeaderController"> |
|
| 41 |
+ |
|
| 42 |
+ <ul class="nav navbar-nav" > |
|
| 43 |
+ <li ng-class="{ active: isActive('/')}"><a href="#/">Home</a></li>
|
|
| 44 |
+ <li ng-class="{ active: isActive('/domains')}"><a href="#/domains">domains</a></li>
|
|
| 45 |
+ <li ng-class="{ active: isActive('/sign_in')}"><a href="#/sign_in">Sign in</a></li>
|
|
| 46 |
+ </ul> |
|
| 47 |
+ </div> |
|
| 48 |
+ </div> |
|
| 49 |
+ </div> |
|
| 50 |
+ </div> |
|
| 51 |
+ |
|
| 52 |
+ <div class="container"> |
|
| 53 |
+ <div ng-view=""></div> |
|
| 54 |
+ </div> |
|
| 55 |
+ |
|
| 56 |
+ <div footer></div> |
|
| 57 |
+ |
|
| 58 |
+ |
|
| 59 |
+ <!-- Google Analytics: change UA-XXXXX-X to be your site's ID --> |
|
| 60 |
+ <script> |
|
| 61 |
+ !function(A,n,g,u,l,a,r){A.GoogleAnalyticsObject=l,A[l]=A[l]||function(){
|
|
| 62 |
+ (A[l].q=A[l].q||[]).push(arguments)},A[l].l=+new Date,a=n.createElement(g), |
|
| 63 |
+ r=n.getElementsByTagName(g)[0],a.src=u,r.parentNode.insertBefore(a,r) |
|
| 64 |
+ }(window,document,'script','//www.google-analytics.com/analytics.js','ga'); |
|
| 65 |
+ |
|
| 66 |
+ ga('create', 'UA-XXXXX-X');
|
|
| 67 |
+ ga('send', 'pageview');
|
|
| 68 |
+ </script> |
|
| 69 |
+ |
|
| 70 |
+ <!-- build:js(.) scripts/vendor.js --> |
|
| 71 |
+ <!-- bower:js --> |
|
| 72 |
+ <script src="bower_components/jquery/dist/jquery.js"></script> |
|
| 73 |
+ <script src="bower_components/angular/angular.js"></script> |
|
| 74 |
+ <script src="bower_components/bootstrap/dist/js/bootstrap.js"></script> |
|
| 75 |
+ <script src="bower_components/angular-animate/angular-animate.js"></script> |
|
| 76 |
+ <script src="bower_components/angular-cookies/angular-cookies.js"></script> |
|
| 77 |
+ <script src="bower_components/angular-resource/angular-resource.js"></script> |
|
| 78 |
+ <script src="bower_components/angular-route/angular-route.js"></script> |
|
| 79 |
+ <script src="bower_components/angular-sanitize/angular-sanitize.js"></script> |
|
| 80 |
+ <script src="bower_components/angular-touch/angular-touch.js"></script> |
|
| 81 |
+ <script src="bower_components/firebase/firebase.js"></script> |
|
| 82 |
+ <script src="bower_components/angularfire/dist/angularfire.js"></script> |
|
| 83 |
+ <script src="bower_components/spin.js/spin.js"></script> |
|
| 84 |
+ <script src="bower_components/ladda/dist/ladda.min.js"></script> |
|
| 85 |
+ <script src="bower_components/angular-ladda/dist/angular-ladda.min.js"></script> |
|
| 86 |
+ <!-- endbower --> |
|
| 87 |
+ <!-- endbuild --> |
|
| 88 |
+ |
|
| 89 |
+ <!-- build:js({.tmp,app}) scripts/scripts.js -->
|
|
| 90 |
+ <script src="scripts/app.js"></script> |
|
| 91 |
+ <script src="scripts/controllers/main.js"></script> |
|
| 92 |
+ <script src="scripts/controllers/domainsList.js"></script> |
|
| 93 |
+ <script src="scripts/controllers/signin.js"></script> |
|
| 94 |
+ <script src="scripts/controllers/header.js"></script> |
|
| 95 |
+ <script src="scripts/directives/footer.js"></script> |
|
| 96 |
+ <!-- endbuild --> |
|
| 97 |
+ <scriptsrc="https://cdn.firebase.com/js/simple-login/1.6.2/firebase-simple-login.js"></script> |
|
| 98 |
+</body> |
|
| 99 |
+</html> |
@@ -0,0 +1,3 @@ |
||
| 1 |
+# robotstxt.org |
|
| 2 |
+ |
|
| 3 |
+User-agent: * |
@@ -0,0 +1,41 @@ |
||
| 1 |
+'use strict'; |
|
| 2 |
+ |
|
| 3 |
+/** |
|
| 4 |
+ * @ngdoc overview |
|
| 5 |
+ * @name domainManagerApp |
|
| 6 |
+ * @description |
|
| 7 |
+ * # domainManagerApp |
|
| 8 |
+ * |
|
| 9 |
+ * Main module of the application. |
|
| 10 |
+ */ |
|
| 11 |
+angular |
|
| 12 |
+ .module('domainManagerApp', [
|
|
| 13 |
+ 'ngAnimate', |
|
| 14 |
+ 'ngCookies', |
|
| 15 |
+ 'ngResource', |
|
| 16 |
+ 'ngRoute', |
|
| 17 |
+ 'ngSanitize', |
|
| 18 |
+ 'ngTouch', |
|
| 19 |
+ 'firebase', |
|
| 20 |
+ 'domainManagerApp.main', |
|
| 21 |
+ 'domainManagerApp.signin', |
|
| 22 |
+ 'domainManagerApp.domains' |
|
| 23 |
+ ]) |
|
| 24 |
+ .config(['$routeProvider', function($routeProvider) {
|
|
| 25 |
+ $routeProvider |
|
| 26 |
+ .when('/', {
|
|
| 27 |
+ templateUrl: 'views/main.html', |
|
| 28 |
+ controller: 'MainCtrl' |
|
| 29 |
+ }) |
|
| 30 |
+ .when('/domains', {
|
|
| 31 |
+ templateUrl: 'views/domains.html', |
|
| 32 |
+ controller: 'DomainsListController' |
|
| 33 |
+ }) |
|
| 34 |
+ .when('/sign_in', {
|
|
| 35 |
+ templateUrl: 'views/signin.html', |
|
| 36 |
+ controller: 'SignInController' |
|
| 37 |
+ }) |
|
| 38 |
+ .otherwise({
|
|
| 39 |
+ redirectTo: '/' |
|
| 40 |
+ }); |
|
| 41 |
+ }]); |
@@ -0,0 +1,18 @@ |
||
| 1 |
+'use strict'; |
|
| 2 |
+ |
|
| 3 |
+/** |
|
| 4 |
+ * @ngdoc function |
|
| 5 |
+ * @name domainManagerApp.controller:AboutCtrl |
|
| 6 |
+ * @description |
|
| 7 |
+ * # AboutCtrl |
|
| 8 |
+ * Controller of the domainManagerApp |
|
| 9 |
+ */ |
|
| 10 |
+angular.module('domainManagerApp.domains', [])
|
|
| 11 |
+ .controller('DomainsListController', function ($scope, $http) {
|
|
| 12 |
+ $http({
|
|
| 13 |
+ method: 'GET', |
|
| 14 |
+ url: '/scripts/data.json' |
|
| 15 |
+ }).success(function(data) {
|
|
| 16 |
+ $scope.domains = data.domains; |
|
| 17 |
+ }) |
|
| 18 |
+ }); |
@@ -0,0 +1,15 @@ |
||
| 1 |
+'use strict'; |
|
| 2 |
+ |
|
| 3 |
+/** |
|
| 4 |
+ * @ngdoc function |
|
| 5 |
+ * @name domainManagerApp.controller:MainCtrl |
|
| 6 |
+ * @description |
|
| 7 |
+ * # MainCtrl |
|
| 8 |
+ * Controller of the domainManagerApp |
|
| 9 |
+ */ |
|
| 10 |
+angular.module('domainManagerApp')
|
|
| 11 |
+ .controller('HeaderController', function ($scope, $location) {
|
|
| 12 |
+ $scope.isActive = function (viewLocation) {
|
|
| 13 |
+ return viewLocation === $location.path(); |
|
| 14 |
+ }; |
|
| 15 |
+ }); |
@@ -0,0 +1,17 @@ |
||
| 1 |
+'use strict'; |
|
| 2 |
+ |
|
| 3 |
+/** |
|
| 4 |
+ * @ngdoc function |
|
| 5 |
+ * @name domainManagerApp.controller:MainCtrl |
|
| 6 |
+ * @description |
|
| 7 |
+ * # MainCtrl |
|
| 8 |
+ * Controller of the domainManagerApp |
|
| 9 |
+ */ |
|
| 10 |
+ angular.module('domainManagerApp.main', ['firebase'])
|
|
| 11 |
+ .controller('MainCtrl', function ($scope) {
|
|
| 12 |
+ $scope.awesomeThings = [ |
|
| 13 |
+ 'HTML5 Boilerplate', |
|
| 14 |
+ 'AngularJS', |
|
| 15 |
+ 'Karma' |
|
| 16 |
+ ]; |
|
| 17 |
+ }); |
@@ -0,0 +1,30 @@ |
||
| 1 |
+'use strict'; |
|
| 2 |
+ |
|
| 3 |
+/** |
|
| 4 |
+ * @ngdoc function |
|
| 5 |
+ * @name domainManagerApp.controller:MainCtrl |
|
| 6 |
+ * @description |
|
| 7 |
+ * # MainCtrl |
|
| 8 |
+ * Controller of the domainManagerApp |
|
| 9 |
+ */ |
|
| 10 |
+ angular.module('domainManagerApp.signin', ['firebase'])
|
|
| 11 |
+ .controller('SignInController', ['$scope', '$firebaseAuth', function ($scope, $firebaseAuth) {
|
|
| 12 |
+ |
|
| 13 |
+ var firebaseObj = new Firebase("https://j1x-cpanel.firebaseio.com");
|
|
| 14 |
+ $scope.authObj = $firebaseAuth(firebaseObj); |
|
| 15 |
+ |
|
| 16 |
+ $scope.SignIn = function(event) {
|
|
| 17 |
+ event.preventDefault(); // To prevent form refresh |
|
| 18 |
+ var username = $scope.user.email; |
|
| 19 |
+ var password = $scope.user.password; |
|
| 20 |
+ |
|
| 21 |
+ $scope.authObj.$authWithPassword({
|
|
| 22 |
+ email: username, |
|
| 23 |
+ password: password |
|
| 24 |
+ }).then(function(authData) {
|
|
| 25 |
+ console.log("Logged in as:", authData.uid);
|
|
| 26 |
+ }).catch(function(error) {
|
|
| 27 |
+ console.error("Authentication failed:", error);
|
|
| 28 |
+ }); |
|
| 29 |
+ } |
|
| 30 |
+ }]); |
@@ -0,0 +1,36 @@ |
||
| 1 |
+{
|
|
| 2 |
+ "domains" : [ |
|
| 3 |
+ {
|
|
| 4 |
+ "name" : "jamesperet.com", |
|
| 5 |
+ "status" : "OK", |
|
| 6 |
+ "owner" : "James Peret", |
|
| 7 |
+ "registrart" : "NT10", |
|
| 8 |
+ "registration_date" : "", |
|
| 9 |
+ "expiration_date" : "" |
|
| 10 |
+ }, |
|
| 11 |
+ {
|
|
| 12 |
+ "name" : "jamesperet.com.br", |
|
| 13 |
+ "status" : "OK", |
|
| 14 |
+ "owner" : "James Peret", |
|
| 15 |
+ "registrart" : "NT10", |
|
| 16 |
+ "registration_date" : "", |
|
| 17 |
+ "expiration_date" : "" |
|
| 18 |
+ }, |
|
| 19 |
+ {
|
|
| 20 |
+ "name" : "higheffects.com", |
|
| 21 |
+ "status" : "OK", |
|
| 22 |
+ "owner" : "James Peret", |
|
| 23 |
+ "registrart" : "NT10", |
|
| 24 |
+ "registration_date" : "", |
|
| 25 |
+ "expiration_date" : "" |
|
| 26 |
+ }, |
|
| 27 |
+ {
|
|
| 28 |
+ "name" : "higheffects.com.br", |
|
| 29 |
+ "status" : "OK", |
|
| 30 |
+ "owner" : "James Peret", |
|
| 31 |
+ "registrart" : "NT10", |
|
| 32 |
+ "registration_date" : "", |
|
| 33 |
+ "expiration_date" : "" |
|
| 34 |
+ } |
|
| 35 |
+ ] |
|
| 36 |
+} |
@@ -0,0 +1,11 @@ |
||
| 1 |
+angular.module('domainManagerApp')
|
|
| 2 |
+ .directive('footer', function () {
|
|
| 3 |
+ return {
|
|
| 4 |
+ restrict: 'A', //This menas that it will be used as an attribute and NOT as an element. I don't like creating custom HTML elements |
|
| 5 |
+ replace: true, |
|
| 6 |
+ templateUrl: "../../views/footer.html", |
|
| 7 |
+ controller: ['$scope', '$filter', function ($scope, $filter) {
|
|
| 8 |
+ // code goes here |
|
| 9 |
+ }] |
|
| 10 |
+ } |
|
| 11 |
+ }); |
@@ -0,0 +1,139 @@ |
||
| 1 |
+.browsehappy {
|
|
| 2 |
+ margin: 0.2em 0; |
|
| 3 |
+ background: #ccc; |
|
| 4 |
+ color: #000; |
|
| 5 |
+ padding: 0.2em 0; |
|
| 6 |
+} |
|
| 7 |
+ |
|
| 8 |
+body {
|
|
| 9 |
+ padding: 0; |
|
| 10 |
+ background-color: #eee; |
|
| 11 |
+} |
|
| 12 |
+ |
|
| 13 |
+body.ng-scope {padding: 0px;}
|
|
| 14 |
+ |
|
| 15 |
+/* Everything but the jumbotron gets side spacing for mobile first views */ |
|
| 16 |
+.header, |
|
| 17 |
+.marketing, |
|
| 18 |
+.footer {
|
|
| 19 |
+ padding-left: 15px; |
|
| 20 |
+ padding-right: 15px; |
|
| 21 |
+} |
|
| 22 |
+ |
|
| 23 |
+/* Custom page header */ |
|
| 24 |
+.header {
|
|
| 25 |
+ border-bottom: 1px solid #e5e5e5; |
|
| 26 |
+ margin-bottom: 10px; |
|
| 27 |
+} |
|
| 28 |
+/* Make the masthead heading the same height as the navigation */ |
|
| 29 |
+.header h3 {
|
|
| 30 |
+ margin-top: 0; |
|
| 31 |
+ margin-bottom: 0; |
|
| 32 |
+ line-height: 40px; |
|
| 33 |
+ padding-bottom: 19px; |
|
| 34 |
+} |
|
| 35 |
+ |
|
| 36 |
+/* Custom page footer */ |
|
| 37 |
+.footer {
|
|
| 38 |
+ padding-top: 19px; |
|
| 39 |
+ color: #777; |
|
| 40 |
+ border-top: 1px solid #e5e5e5; |
|
| 41 |
+} |
|
| 42 |
+ |
|
| 43 |
+.container-narrow > hr {
|
|
| 44 |
+ margin: 30px 0; |
|
| 45 |
+} |
|
| 46 |
+ |
|
| 47 |
+/* Main marketing message and sign up button */ |
|
| 48 |
+.jumbotron {
|
|
| 49 |
+ text-align: center; |
|
| 50 |
+ border-bottom: 1px solid #e5e5e5; |
|
| 51 |
+} |
|
| 52 |
+.jumbotron .btn {
|
|
| 53 |
+ font-size: 21px; |
|
| 54 |
+ padding: 14px 24px; |
|
| 55 |
+} |
|
| 56 |
+ |
|
| 57 |
+/* Supporting marketing content */ |
|
| 58 |
+.marketing {
|
|
| 59 |
+ margin: 40px 0; |
|
| 60 |
+} |
|
| 61 |
+.marketing p + h4 {
|
|
| 62 |
+ margin-top: 28px; |
|
| 63 |
+} |
|
| 64 |
+ |
|
| 65 |
+/* Responsive: Portrait tablets and up */ |
|
| 66 |
+@media screen and (min-width: 768px) {
|
|
| 67 |
+ .container {
|
|
| 68 |
+ max-width: 730px; |
|
| 69 |
+ } |
|
| 70 |
+ |
|
| 71 |
+ /* Remove the padding we set earlier */ |
|
| 72 |
+ .header, |
|
| 73 |
+ .marketing, |
|
| 74 |
+ .footer {
|
|
| 75 |
+ padding-left: 0; |
|
| 76 |
+ padding-right: 0; |
|
| 77 |
+ } |
|
| 78 |
+ /* Space out the masthead */ |
|
| 79 |
+ .header {
|
|
| 80 |
+ margin-bottom: 30px; |
|
| 81 |
+ } |
|
| 82 |
+ /* Remove the bottom border on the jumbotron for visual effect */ |
|
| 83 |
+ .jumbotron {
|
|
| 84 |
+ border-bottom: 0; |
|
| 85 |
+ margin-bottom: 0px; |
|
| 86 |
+ padding-top: 10px; |
|
| 87 |
+ } |
|
| 88 |
+} |
|
| 89 |
+ |
|
| 90 |
+/* Bootstrap Signup Styles */ |
|
| 91 |
+ |
|
| 92 |
+.form-signin {
|
|
| 93 |
+ max-width: 330px; |
|
| 94 |
+ padding: 15px; |
|
| 95 |
+ margin: 0 auto; |
|
| 96 |
+ margin-bottom: 45px; |
|
| 97 |
+} |
|
| 98 |
+.form-signin .form-signin-heading, |
|
| 99 |
+.form-signin .checkbox {
|
|
| 100 |
+ margin-bottom: 10px; |
|
| 101 |
+} |
|
| 102 |
+.form-signin .checkbox {
|
|
| 103 |
+ font-weight: normal; |
|
| 104 |
+} |
|
| 105 |
+.form-signin .form-control {
|
|
| 106 |
+ position: relative; |
|
| 107 |
+ height: auto; |
|
| 108 |
+ -webkit-box-sizing: border-box; |
|
| 109 |
+ -moz-box-sizing: border-box; |
|
| 110 |
+ box-sizing: border-box; |
|
| 111 |
+ padding: 10px; |
|
| 112 |
+ font-size: 16px; |
|
| 113 |
+} |
|
| 114 |
+.form-signin .form-control:focus {
|
|
| 115 |
+ z-index: 2; |
|
| 116 |
+} |
|
| 117 |
+.form-signin input[type="email"] {
|
|
| 118 |
+ margin-bottom: -1px; |
|
| 119 |
+ border-bottom-right-radius: 0; |
|
| 120 |
+ border-bottom-left-radius: 0; |
|
| 121 |
+} |
|
| 122 |
+.form-signin input[type="password"] {
|
|
| 123 |
+ margin-bottom: 10px; |
|
| 124 |
+ border-top-left-radius: 0; |
|
| 125 |
+ border-top-right-radius: 0; |
|
| 126 |
+} |
|
| 127 |
+ |
|
| 128 |
+h1.j1x-logo {
|
|
| 129 |
+ text-transform: uppercase; |
|
| 130 |
+ font-weight: 600; |
|
| 131 |
+ font-size: 120px; |
|
| 132 |
+ margin-bottom: 0px; |
|
| 133 |
+} |
|
| 134 |
+ |
|
| 135 |
+.form-title {
|
|
| 136 |
+ text-align: center; |
|
| 137 |
+ margin-bottom: 20px; |
|
| 138 |
+ margin-top: 0px; |
|
| 139 |
+} |
@@ -0,0 +1,3 @@ |
||
| 1 |
+<ul> |
|
| 2 |
+ <li ng-repeat="domain in domains">{{domain.name}}</li>
|
|
| 3 |
+</ul> |
@@ -0,0 +1,5 @@ |
||
| 1 |
+<div class="footer"> |
|
| 2 |
+ <div class="container"> |
|
| 3 |
+ <p><span class="glyphicon glyphicon-heart"></span> from the Yeoman team</p> |
|
| 4 |
+ </div> |
|
| 5 |
+</div> |
@@ -0,0 +1,8 @@ |
||
| 1 |
+<div class="container"> |
|
| 2 |
+ <div class="jumbotron" style="padding-bottom:15px;"> |
|
| 3 |
+ <h1 class="j1x-logo">J1X</h1> |
|
| 4 |
+ <h2>Domain Manager</h2> |
|
| 5 |
+ </div> |
|
| 6 |
+ |
|
| 7 |
+ |
|
| 8 |
+</div> |
@@ -0,0 +1,13 @@ |
||
| 1 |
+<div class="container"> |
|
| 2 |
+ <div class="jumbotron" style="padding-bottom:15px;"> |
|
| 3 |
+ <h1 class="j1x-logo">J1X</h1> |
|
| 4 |
+ |
|
| 5 |
+ </div> |
|
| 6 |
+ <form class="form-signin" role="form"> |
|
| 7 |
+ <h2 class="form-title">Login</h2> |
|
| 8 |
+ <input ng-model="user.email" type="email" class="form-control" placeholder="Email address" required="" autofocus=""> |
|
| 9 |
+ <input ng-model="user.password" type="password" class="form-control" placeholder="Password" required=""> |
|
| 10 |
+ <button type="button" ng-click="SignIn($event)" class="btn btn-lg btn-primary btn-block">SignIn</button> |
|
| 11 |
+ </form> |
|
| 12 |
+ |
|
| 13 |
+</div> |
@@ -0,0 +1,21 @@ |
||
| 1 |
+{
|
|
| 2 |
+ "name": "domain-manager", |
|
| 3 |
+ "version": "0.0.0", |
|
| 4 |
+ "dependencies": {
|
|
| 5 |
+ "angular": "^1.3.0", |
|
| 6 |
+ "bootstrap": "^3.2.0", |
|
| 7 |
+ "angular-animate": "^1.3.0", |
|
| 8 |
+ "angular-cookies": "^1.3.0", |
|
| 9 |
+ "angular-resource": "^1.3.0", |
|
| 10 |
+ "angular-route": "^1.3.0", |
|
| 11 |
+ "angular-sanitize": "^1.3.0", |
|
| 12 |
+ "angular-touch": "^1.3.0", |
|
| 13 |
+ "angularfire": "~1.1.1", |
|
| 14 |
+ "angular-ladda": "~0.2.2" |
|
| 15 |
+ }, |
|
| 16 |
+ "devDependencies": {
|
|
| 17 |
+ "angular-mocks": "^1.3.0" |
|
| 18 |
+ }, |
|
| 19 |
+ "appPath": "app", |
|
| 20 |
+ "moduleName": "domainManagerApp" |
|
| 21 |
+} |
@@ -0,0 +1,41 @@ |
||
| 1 |
+{
|
|
| 2 |
+ "name": "domainmanager", |
|
| 3 |
+ "version": "0.0.0", |
|
| 4 |
+ "dependencies": {},
|
|
| 5 |
+ "repository": {},
|
|
| 6 |
+ "devDependencies": {
|
|
| 7 |
+ "grunt": "^0.4.5", |
|
| 8 |
+ "grunt-autoprefixer": "^2.0.0", |
|
| 9 |
+ "grunt-concurrent": "^1.0.0", |
|
| 10 |
+ "grunt-contrib-clean": "^0.6.0", |
|
| 11 |
+ "grunt-contrib-concat": "^0.5.0", |
|
| 12 |
+ "grunt-contrib-connect": "^0.9.0", |
|
| 13 |
+ "grunt-contrib-copy": "^0.7.0", |
|
| 14 |
+ "grunt-contrib-cssmin": "^0.12.0", |
|
| 15 |
+ "grunt-contrib-htmlmin": "^0.4.0", |
|
| 16 |
+ "grunt-contrib-imagemin": "^0.9.2", |
|
| 17 |
+ "grunt-contrib-jshint": "^0.11.0", |
|
| 18 |
+ "grunt-contrib-uglify": "^0.7.0", |
|
| 19 |
+ "grunt-contrib-watch": "^0.6.1", |
|
| 20 |
+ "grunt-filerev": "^2.1.2", |
|
| 21 |
+ "grunt-google-cdn": "^0.4.3", |
|
| 22 |
+ "grunt-karma": "*", |
|
| 23 |
+ "grunt-newer": "^1.1.0", |
|
| 24 |
+ "grunt-ng-annotate": "^0.9.2", |
|
| 25 |
+ "grunt-svgmin": "^2.0.0", |
|
| 26 |
+ "grunt-usemin": "^3.0.0", |
|
| 27 |
+ "grunt-wiredep": "^2.0.0", |
|
| 28 |
+ "jshint": "^2.7.0", |
|
| 29 |
+ "jshint-stylish": "^1.0.0", |
|
| 30 |
+ "karma-jasmine": "*", |
|
| 31 |
+ "karma-phantomjs-launcher": "*", |
|
| 32 |
+ "load-grunt-tasks": "^3.1.0", |
|
| 33 |
+ "time-grunt": "^1.0.0" |
|
| 34 |
+ }, |
|
| 35 |
+ "engines": {
|
|
| 36 |
+ "node": ">=0.10.0" |
|
| 37 |
+ }, |
|
| 38 |
+ "scripts": {
|
|
| 39 |
+ "test": "grunt test" |
|
| 40 |
+ } |
|
| 41 |
+} |
@@ -0,0 +1,28 @@ |
||
| 1 |
+{
|
|
| 2 |
+ "node": true, |
|
| 3 |
+ "browser": true, |
|
| 4 |
+ "esnext": true, |
|
| 5 |
+ "bitwise": true, |
|
| 6 |
+ "camelcase": true, |
|
| 7 |
+ "curly": true, |
|
| 8 |
+ "eqeqeq": true, |
|
| 9 |
+ "immed": true, |
|
| 10 |
+ "indent": 2, |
|
| 11 |
+ "latedef": true, |
|
| 12 |
+ "newcap": true, |
|
| 13 |
+ "noarg": true, |
|
| 14 |
+ "quotmark": "single", |
|
| 15 |
+ "regexp": true, |
|
| 16 |
+ "undef": true, |
|
| 17 |
+ "unused": true, |
|
| 18 |
+ "strict": true, |
|
| 19 |
+ "trailing": true, |
|
| 20 |
+ "smarttabs": true, |
|
| 21 |
+ "jasmine": true, |
|
| 22 |
+ "globals": {
|
|
| 23 |
+ "angular": false, |
|
| 24 |
+ "browser": false, |
|
| 25 |
+ "inject": false |
|
| 26 |
+ } |
|
| 27 |
+} |
|
| 28 |
+ |
@@ -0,0 +1,88 @@ |
||
| 1 |
+// Karma configuration |
|
| 2 |
+// http://karma-runner.github.io/0.12/config/configuration-file.html |
|
| 3 |
+// Generated on 2015-05-16 using |
|
| 4 |
+// generator-karma 1.0.0 |
|
| 5 |
+ |
|
| 6 |
+module.exports = function(config) {
|
|
| 7 |
+ 'use strict'; |
|
| 8 |
+ |
|
| 9 |
+ config.set({
|
|
| 10 |
+ // enable / disable watching file and executing tests whenever any file changes |
|
| 11 |
+ autoWatch: true, |
|
| 12 |
+ |
|
| 13 |
+ // base path, that will be used to resolve files and exclude |
|
| 14 |
+ basePath: '../', |
|
| 15 |
+ |
|
| 16 |
+ // testing framework to use (jasmine/mocha/qunit/...) |
|
| 17 |
+ // as well as any additional frameworks (requirejs/chai/sinon/...) |
|
| 18 |
+ frameworks: [ |
|
| 19 |
+ "jasmine" |
|
| 20 |
+ ], |
|
| 21 |
+ |
|
| 22 |
+ // list of files / patterns to load in the browser |
|
| 23 |
+ files: [ |
|
| 24 |
+ // bower:js |
|
| 25 |
+ 'bower_components/jquery/dist/jquery.js', |
|
| 26 |
+ 'bower_components/angular/angular.js', |
|
| 27 |
+ 'bower_components/bootstrap/dist/js/bootstrap.js', |
|
| 28 |
+ 'bower_components/angular-animate/angular-animate.js', |
|
| 29 |
+ 'bower_components/angular-cookies/angular-cookies.js', |
|
| 30 |
+ 'bower_components/angular-resource/angular-resource.js', |
|
| 31 |
+ 'bower_components/angular-route/angular-route.js', |
|
| 32 |
+ 'bower_components/angular-sanitize/angular-sanitize.js', |
|
| 33 |
+ 'bower_components/angular-touch/angular-touch.js', |
|
| 34 |
+ 'bower_components/firebase/firebase.js', |
|
| 35 |
+ 'bower_components/angularfire/dist/angularfire.js', |
|
| 36 |
+ 'bower_components/spin.js/spin.js', |
|
| 37 |
+ 'bower_components/ladda/dist/ladda.min.js', |
|
| 38 |
+ 'bower_components/angular-ladda/dist/angular-ladda.min.js', |
|
| 39 |
+ 'bower_components/angular-mocks/angular-mocks.js', |
|
| 40 |
+ // endbower |
|
| 41 |
+ "app/scripts/**/*.js", |
|
| 42 |
+ "test/mock/**/*.js", |
|
| 43 |
+ "test/spec/**/*.js" |
|
| 44 |
+ ], |
|
| 45 |
+ |
|
| 46 |
+ // list of files / patterns to exclude |
|
| 47 |
+ exclude: [ |
|
| 48 |
+ ], |
|
| 49 |
+ |
|
| 50 |
+ // web server port |
|
| 51 |
+ port: 8080, |
|
| 52 |
+ |
|
| 53 |
+ // Start these browsers, currently available: |
|
| 54 |
+ // - Chrome |
|
| 55 |
+ // - ChromeCanary |
|
| 56 |
+ // - Firefox |
|
| 57 |
+ // - Opera |
|
| 58 |
+ // - Safari (only Mac) |
|
| 59 |
+ // - PhantomJS |
|
| 60 |
+ // - IE (only Windows) |
|
| 61 |
+ browsers: [ |
|
| 62 |
+ "PhantomJS" |
|
| 63 |
+ ], |
|
| 64 |
+ |
|
| 65 |
+ // Which plugins to enable |
|
| 66 |
+ plugins: [ |
|
| 67 |
+ "karma-phantomjs-launcher", |
|
| 68 |
+ "karma-jasmine" |
|
| 69 |
+ ], |
|
| 70 |
+ |
|
| 71 |
+ // Continuous Integration mode |
|
| 72 |
+ // if true, it capture browsers, run tests and exit |
|
| 73 |
+ singleRun: false, |
|
| 74 |
+ |
|
| 75 |
+ colors: true, |
|
| 76 |
+ |
|
| 77 |
+ // level of logging |
|
| 78 |
+ // possible values: LOG_DISABLE || LOG_ERROR || LOG_WARN || LOG_INFO || LOG_DEBUG |
|
| 79 |
+ logLevel: config.LOG_INFO, |
|
| 80 |
+ |
|
| 81 |
+ // Uncomment the following lines if you are using grunt's server to run the tests |
|
| 82 |
+ // proxies: {
|
|
| 83 |
+ // '/': 'http://localhost:9000/' |
|
| 84 |
+ // }, |
|
| 85 |
+ // URL root prevent conflicts with the site root |
|
| 86 |
+ // urlRoot: '_karma_' |
|
| 87 |
+ }); |
|
| 88 |
+}; |
@@ -0,0 +1,22 @@ |
||
| 1 |
+'use strict'; |
|
| 2 |
+ |
|
| 3 |
+describe('Controller: AboutCtrl', function () {
|
|
| 4 |
+ |
|
| 5 |
+ // load the controller's module |
|
| 6 |
+ beforeEach(module('domainManagerApp'));
|
|
| 7 |
+ |
|
| 8 |
+ var AboutCtrl, |
|
| 9 |
+ scope; |
|
| 10 |
+ |
|
| 11 |
+ // Initialize the controller and a mock scope |
|
| 12 |
+ beforeEach(inject(function ($controller, $rootScope) {
|
|
| 13 |
+ scope = $rootScope.$new(); |
|
| 14 |
+ AboutCtrl = $controller('AboutCtrl', {
|
|
| 15 |
+ $scope: scope |
|
| 16 |
+ }); |
|
| 17 |
+ })); |
|
| 18 |
+ |
|
| 19 |
+ it('should attach a list of awesomeThings to the scope', function () {
|
|
| 20 |
+ expect(scope.awesomeThings.length).toBe(3); |
|
| 21 |
+ }); |
|
| 22 |
+}); |
@@ -0,0 +1,22 @@ |
||
| 1 |
+'use strict'; |
|
| 2 |
+ |
|
| 3 |
+describe('Controller: MainCtrl', function () {
|
|
| 4 |
+ |
|
| 5 |
+ // load the controller's module |
|
| 6 |
+ beforeEach(module('domainManagerApp'));
|
|
| 7 |
+ |
|
| 8 |
+ var MainCtrl, |
|
| 9 |
+ scope; |
|
| 10 |
+ |
|
| 11 |
+ // Initialize the controller and a mock scope |
|
| 12 |
+ beforeEach(inject(function ($controller, $rootScope) {
|
|
| 13 |
+ scope = $rootScope.$new(); |
|
| 14 |
+ MainCtrl = $controller('MainCtrl', {
|
|
| 15 |
+ $scope: scope |
|
| 16 |
+ }); |
|
| 17 |
+ })); |
|
| 18 |
+ |
|
| 19 |
+ it('should attach a list of awesomeThings to the scope', function () {
|
|
| 20 |
+ expect(scope.awesomeThings.length).toBe(3); |
|
| 21 |
+ }); |
|
| 22 |
+}); |